JAVA读取csv文件 您所在的位置:网站首页 java csv读取 JAVA读取csv文件

JAVA读取csv文件

2024-06-18 01:35| 来源: 网络整理| 查看: 265

csv文件的介绍

以下是来自百度百科的介绍

逗号分隔值(Comma-Separated Values,CSV,有时也称为字符分隔值,因为分隔字符也可以不是逗号),其文件以纯文本形式存储表格数据(数字和文本)。纯文本意味着该文件是一个字符序列,不含必须像二进制数字那样被解读的数据。CSV文件由任意数目的记录组成,记录间以某种换行符分隔;每条记录由字段组成,字段间的分隔符是其它字符或字符串,最常见的是逗号或制表符。通常,所有记录都有完全相同的字段序列。通常都是纯文本文件。建议使用WORDPAD或是记事本来开启,再则先另存新档后用EXCEL开启,也是方法之一。

csv文件的读取方式1、java原生方式

当读取的是一个简单的csv文件,即文件的列字段中不包含分隔符时,可以使用BufferedReader或者Scanner类去读取

BufferedReader方式

代码语言:javascript复制// 创建 reader try (BufferedReader br = Files.newBufferedReader(Paths.get("users.csv"))) { // CSV文件的分隔符 String DELIMITER = ","; // 按行读取 String line; while ((line = br.readLine()) != null) { // 分割 String[] columns = line.split(DELIMITER); // 打印行 System.out.println("User["+ String.join(", ", columns) +"]"); } } catch (IOException ex) { ex.printStackTrace(); }

Jetbrains全家桶1年46,售后保障稳定

输出

代码语言:javascript复制User[1, John Doe, [email protected], AE] User[2, Alex Jones, [email protected], DE] User[3, Jovan Lee, [email protected], FR] User[4, Greg Hover, [email protected], US]

Scanner方式

代码语言:javascript复制// 创建scanner try (Scanner scanner = new Scanner(Paths.get("users.csv").toFile())) { // CSV文件分隔符 String DELIMITER = ","; // 设置分隔符 scanner.useDelimiter(DELIMITER); // 读取 while (scanner.hasNext()) { System.out.print(scanner.next() + " "); } } catch (IOException ex) { ex.printStackTrace(); }

输出

代码语言:javascript复制1 John Doe [email protected] AE 2 Alex Jones [email protected] DE 3 Jovan Lee [email protected] FR 4 Greg Hover [email protected] US 2、第三方库

第三方库提供更加丰富且成熟的功能,可以更加方便的读和写,版本号可以使用最新版

OpenCSV

pom中引入以下jar

代码语言:javascript复制 com.opencsv opencsv 5.0

读文件:

代码语言:javascript复制try (Reader reader = Files.newBufferedReader(Paths.get("users.csv")); CSVReader csvReader = new CSVReader(reader)) { String[] record; while ((record = csvReader.readNext()) != null) { System.out.println("User["+ String.join(", ", record) +"]"); } } catch (IOException | CsvValidationException ex) { ex.printStackTrace(); }Apache Commons CSV

pom中引入以下jar

代码语言:javascript复制 org.apache.commons commons-csv 1.7

读文件:

代码语言:javascript复制try (Reader reader = Files.newBufferedReader(Paths.get("users.csv"))) { Iterable records = CSVFormat.DEFAULT.parse(reader); for (CSVRecord record : records) { System.out.println("Record #: " + record.getRecordNumber()); System.out.println("ID: " + record.get(0)); System.out.println("Name: " + record.get(1)); System.out.println("Email: " + record.get(2)); System.out.println("Country: " + record.get(3)); } } catch (IOException ex) { ex.printStackTrace(); }javacsv

个人使用的是这种方法,可以查看API手册,其实也不用单独查看,在使用中学习即可,pom中引入以下jar

代码语言:javascript复制 net.sourceforge.javacsv javacsv 2.0

读文件:

代码语言:javascript复制public static void read() throws IOException { // 第一参数:读取文件的路径 第二个参数:分隔符(不懂仔细查看引用百度百科的那段话) 第三个参数:字符集 CsvReader csvReader = new CsvReader("F:/demo.csv", ',', Charset.forName("UTF-8")); // 如果你的文件没有表头,这行不用执行 // 这行不要是为了从表头的下一行读,也就是过滤表头 csvReader.readHeaders(); // 读取每行的内容 while (csvReader.readRecord()) { // 获取内容的两种方式 // 1. 通过下标获取 System.out.print(csvReader.get(0)); // 2. 通过表头的文字获取 System.out.println(" " + csvReader.get("年龄")); } }

写文件:

代码语言:javascript复制public static void writer() throws IOException { // 第一参数:新生成文件的路径 第二个参数:分隔符(不懂仔细查看引用百度百科的那段话) 第三个参数:字符集 CsvWriter csvWriter = new CsvWriter("F:/demo.csv", ',', Charset.forName("UTF-8")); // 表头和内容 String[] headers = {"姓名", "年龄", "性别"}; String[] content = {"张三", "18", "男"}; // 写表头和内容,因为csv文件中区分没有那么明确,所以都使用同一函数,写成功就行 csvWriter.writeRecord(headers); csvWriter.writeRecord(content); // 关闭csvWriter csvWriter.close(); }

参考链接

https://attacomsian.com/blog/java-read-parse-csv-filehttps://my.oschina.net/u/2930289/blog/1589704

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/234548.html原文链接:https://javaforall.cn



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有